import NProgress from 'nprogress' // progress bar
import 'nprogress/nprogress.css' // progress bar style

import router from './router'
import store from './store'
// to:要去哪个页面
// from:从哪里来
// next:它是一个函数
//   如果直接放行 next()
//   如果要跳转到其他页 next(页面路径)
const whiteList = ['/login', '/404'] // 白名单列表
router.beforeEach((to, from, next) => {
  NProgress.start() // 开启进度条----->在哪里什么时候开启进度条---->开始跳转页面时开启
  console.log('to去哪里', to.path)
  console.log('from从哪里', from.path)
  // 判断是否登陆, 是否有token
  const token = store.state.user.token
  if (token) {
    // 已经登陆
    if (to.path === '/login') {
      console.log('您已经登陆,直接去首页')
      next('/')
      NProgress.done() // 关闭进度条
      // next('指定了跳转的地址') 就不会经过router.afterEach函数
      // next() 只有放行了的时候会经过router.afterEach函数
    } else {
      console.log('已经登陆,放行')
      next()
    }
  } else {
    // 未登陆
    if (whiteList.includes(to.path)) {
      console.log('拥有白名单,可以直接访问')
      next()
    } else {
      console.log('没有白名单,请先登录')
      next('/login')
      NProgress.done() // 关闭进度条
    }
  }
})
